import random
import re
from datetime import datetime

from flask import request, abort, current_app, make_response, jsonify, session

from info import sr, db
from info.lib.yuntongxun.sms import CCP
from info.models import User
from info.moduies.passport import passport_blu
from info.utils.captcha.pic_captcha import captcha
from info.utils.captcha.response_code import RET, error_map

# 获取图片验证信息
@passport_blu.route('/get_img_code')
def get_img_code():
    # 获取参数，
    img_code_id = request.args.get('img_code_id')
    # 校验参数
    if not img_code_id:
        return abort(403)

    # 生成图片验证码
    img_name,img_text,img_bytes = captcha.generate_captcha()
    # 保留验证码key 和 图片文字内容 （使用redis 方便设置过期时间）
    try:
        sr.set('img_code_id'+img_code_id,img_text,ex=180)
    except BaseException as e:
        current_app.logger.error(e)
        return abort(500)

    # 转换图片制编码
    response = make_response(img_bytes)
    response.content_type='image/jpeg'
    # 返还图片验证码
    return response

# 获取手机验证信息
@passport_blu.route('/get_sms_code',methods=['POST'])
def get_sms_code ():
    # 获取参数
    mobile = request.json.get('mobile') #手机好
    img_code = request.json.get('img_code')  # 图片验证码
    img_code_id = request.json.get('img_code_id') #图片key
    # 校验参数
    if not all([mobile,img_code_id,img_code]):
        return jsonify(errno=RET.PARAMERR,errmsg=error_map[RET.PARAMERR])
    # 校验手机号格式
    if not re.match(r'1[35678]\d{9}$',mobile):
        return jsonify(errno=RET.PARAMERR,errmsg=error_map[RET.PARAMERR])
    # 根据图片key取出验证文字
    try:
        real_img_code = sr.get('img_code_id' + img_code_id)
    except BaseException as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR,errmsg=error_map[RET.DBERR])
    # 判断是否过期
    if not real_img_code:
        return jsonify(errno=RET.PARAMERR,errmsg='验证码已过期')
    # 判断验证码是否正确
    if real_img_code != img_code.upper():
        return jsonify(errno=RET.PARAMERR,errmsg='验证码不正确')

    # 生成随机的短信验证码
    sms_code = "%04d" % random.randint(0, 9999)
    current_app.logger.info("短信验证码为：%s" % sms_code)

    # 发送信息
    # sms = CCP().send_template_sms(mobile, [sms_code, 5], 1)
    # if sms != 0:
    #     return jsonify(errno=RET.THIRDERR,errsmg=error_map[RET.THIRDERR])
    # 保存信息
    try:
        sr.set("sms_code_id" +mobile,sms_code,ex=60)
    except BaseException as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR,errssmg=error_map[RET.DBERR])
    # josn返回发送结果
    return jsonify(errno=RET.OK,errmsg=error_map[RET.OK])

# 注册用户

@passport_blu.route('/register',methods=['POST'])
def register():
    #获取参数
    mobile = request.json.get('mobile') #手机好
    password = request.json.get('password') #密码
    sms_code = request.json.get('sms_code') #验证码信息

    # 教研参数
    if not all([mobile, password, sms_code]):
        return jsonify(errno=RET.PARAMERR, errmsg=error_map[RET.PARAMERR])
    # 校验手机号格式
    if not re.match(r'1[35678]\d{9}$',mobile):

        return jsonify(errno=RET.PARAMERR,errmsg=error_map[RET.PARAMERR])

    # 根据手机号取出短信验证码
    try:
        real_sms_code = sr.get('sms_code_id' + mobile)
    except BaseException as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg=error_map[RET.DBERR])

    # 校验短信验证吗
    if not real_sms_code:

        return jsonify(errno=RET.PARAMERR, errmsg='验证码已过期')
        # 判断验证码是否正确
    if real_sms_code != sms_code.upper():

        return jsonify(errno=RET.PARAMERR, errmsg='验证码不正确')

    # 保留验证码信息
    user = User()
    user.mobile = mobile
    # 封装加密过程
    user.password = password
    user.nick_name = mobile
    # 记录最后登录时间(保存到是一个日期对象)
    user.last_login = datetime.now()

    try:
        db.session.add(user)
        db.session.commit()
    except BaseException as e:
        current_app.logger.error(e)
        db.session.rollback()
        return jsonify(errno=RET.DBERR, errmsg=error_map[RET.DBERR])

    # 状态保持（免密码登录）  保存用户的主键， 就可以取出用户的所有信息
    session["user_id"] = user.id
    # json返回数据信息
    return jsonify(errno=RET.OK,errmsg=error_map[RET.OK])

# 用户登录
@passport_blu.route('/login', methods=['POST'])
def login():
    # 获取参数
    mobile = request.json.get("mobile")
    password = request.json.get("password")
    # 校验参数
    if not all([mobile, password]):
        return jsonify(errno=RET.PARAMERR, errmsg=error_map[RET.PARAMERR])

    # 校验手机号格式
    if not re.match(r"1[35678]\d{9}$", mobile):
        return jsonify(errno=RET.PARAMERR, errmsg=error_map[RET.PARAMERR])

    # 根据手机号查询该用户模型
    try:
        user = User.query.filter_by(mobile=mobile).first()
    except BaseException as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg=error_map[RET.DBERR])
    # 判断用户是否存在
    if not user:
        return jsonify(errno=RET.USERERR, errmsg=error_map[RET.USERERR])

    # 校验密码
    if not user.check_password(password):
        return jsonify(errno=RET.PARAMERR, errmsg="用户名/密码错误")

    # 记录最后登录时间(保存到是一个日期对象)
    user.last_login = datetime.now()

    # 状态保持（免密码登录）  保存用户的主键， 就可以取出用户的所有信息
    session["user_id"] = user.id

    # 返回json
    return jsonify(errno=RET.OK, errmsg=error_map[RET.OK])
# 退出登录
@passport_blu.route('/logout')
def logout():
    # 删除session中的user_id
    session.pop("user_id", None)
    # 将结果以json返回
    return jsonify(errno=RET.OK, errmsg=error_map[RET.OK])